package cn.iocoder.yudao.module.custom.service.city;

import java.util.*;
import javax.validation.*;
import cn.iocoder.yudao.module.custom.controller.admin.city.vo.*;
import cn.iocoder.yudao.module.custom.dal.dataobject.city.CityDO;
import cn.iocoder.yudao.framework.common.pojo.PageResult;

/**
 * 城市信息 Service 接口
 *
 * @author 芋道源码
 */
public interface CityService {

    /**
     * 创建城市信息
     *
     * @param createReqVO 创建信息
     * @return 编号
     */
    String createCity(@Valid CityCreateReqVO createReqVO);

    /**
     * 更新城市信息
     *
     * @param updateReqVO 更新信息
     */
    void updateCity(@Valid CityUpdateReqVO updateReqVO);

    /**
     * 删除城市信息
     *
     * @param id 编号
     */
    void deleteCity(String id);

    /**
     * 获得城市信息
     *
     * @param id 编号
     * @return 城市信息
     */
    CityDO getCity(String id);

    /**
     * 获得城市信息列表
     *
     * @param ids 编号
     * @return 城市信息列表
     */
    List<CityDO> getCityList(Collection<String> ids);

    /**
     * 获得城市信息分页
     *
     * @param pageReqVO 分页查询
     * @return 城市信息分页
     */
    PageResult<CityDO> getCityPage(CityPageReqVO pageReqVO);

    /**
     * 获得城市信息列表, 用于 Excel 导出
     *
     * @param exportReqVO 查询条件
     * @return 城市信息列表
     */
    List<CityDO> getCityList(CityExportReqVO exportReqVO);

    /**
     * 获取下级城市集合
     * @param parentId 上级id
     * @return list
     */
    List<CityDO> getCityLists(Integer parentId);
}
